

# Directives

# R. Ferrero, P. Bernardi Politecnico di Torino

Dipartimento di Automatica e Informatica (DAUIN)

Torino - Italy

This work is licensed under the Creative Commons (CC BY-SA) License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/3.0/



Cose fore se dere fore colcoline une motiva? Come moltiplicalo per une contenté! Come obfinire una contente? Come solvere la matria? DCD 1,2,3,4 E Solve la motice pa righe. li potere onche continuoro mo n'e preferito ondere a Motrix DCD 5,6,7,8 copo por una mazzione logalilità bcs 1, 2, 3, 4 bcs 5, 6, 7, 8 DCD 1, 2, 3, 4 1de consti, = 0 x 16 234367 LDR motrice, = MATRIX LDR muovo\_m, = NEW\_HATENX mor i, #0 for (1=0; i < night; it+) EXT\_LOOP mer 5, #0 -> for (j=0; j < col; j++) INT\_LOOP comments; mor 20, #4 ; mul 20, 20, i ; add so, so, i Il farmo lo terro coso edd 80, 5, i, ese #2 LOR R6, [motrice, R0, LSL#2] -> J. Je X4 (LSL 2) perche obligano delle mul R6 R6, Const. mul R6, R6, court STR Rb, [muoro\_m, Ro, LSL #2] sold j , j , #1

|  |   | cmp      | ,        | terme        | ca         |       |   |  |  |  |  |  |  |  |
|--|---|----------|----------|--------------|------------|-------|---|--|--|--|--|--|--|--|
|  |   | bme      | ،<br>محد | nten         | nol_       | loop  | , |  |  |  |  |  |  |  |
|  |   | oold     | ^        | , ,          | # 1        | V     |   |  |  |  |  |  |  |  |
|  | ( | cmp      | <b>*</b> | . ,<br>. # F | રાહ        |       |   |  |  |  |  |  |  |  |
|  |   | hme.     | e~       | 15000        | <b>Q</b> . | looh. |   |  |  |  |  |  |  |  |
|  |   | <i>J</i> | - Or     |              | J          |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |
|  |   |          |          |              |            |       |   |  |  |  |  |  |  |  |

### Instruction format

A general source line is:

{label} {operation} {; comment}

- operation may be:
  - an instruction
  - a directive
  - a pseudo-instruction

labels must start at the beginning of the line

The instructions, directives, and pseudo-instructions must be preceded by a white space, either a tab or any number of spaces

### Common directives

AREA

SPACE

Defines a block of code or data Can be used to associate a register with a name Equates a symbol to a numeric constant EOU ENTRY Declares an entry point to your program DCD Allocates memory and specifies initial) runtime contents Aligns data or code to a particular memory boundary

Reserves a zeroed block of memory of a particular size

Assigns the starting point of a literal pool LTORG

Designates the end of a source file END:

### Sections of data and code

- The IDE tools need to be told how to treat all the different parts of a program
  - Data sections,
  - Program sections,
  - Blocks of coefficients, etc.
- These sections, which are indivisible and named, then get manipulated by the linker and ultimately end up in the correct type of memory in a system.
  - The data, which could be read-write information, could get stored in RAM,
  - The program code which might end up in Flash memory.

# Sections of data and code (II)

- Normally you will have separate sections for your program and your data, especially in larger programs.
  - The code must have at least one AREA directive in it, which is usually found in the first few lines of a program
  - Blocks of coefficients or tables can be placed in a section of their own.

# Sections of data and code (III)

- AREA sectionName {,attr} {,attr}...
- If sectionName starts with a number, it must be enclosed in bars e.g. |1\_DataArea|
- | .text| is used by the C compiler
- At least one AREA directive is mandatory
- Example: AREA Example, CODE, READONLY

### Section attributes

- CODE: the section contains machine code
- DATA: the section contains data
- READONLY: the section can be placed in read-only memory
- **READWRITE:** the section can be placed in read-write memory
- ALIGN = expr: the section is aligned on a 2expr-byte boundary

## Register names

- r0-r15 or R0-R15
- a1-a4 or r0-r3
- r13, R13, sp, SP
- r14, R14, Ir, LR
- r15, R15, pc, PC
- You can assign other names with RN:

name RN registerIndex

• E.g. coeff1 RN 8

# Declaring constants

• The EQU directive gives a symbolic name to a numeric constant:

- Advantages:
  - readibility
  - easiness in updating the value through the code

### Numbers

- You can express numbers in any base:
  - decimal: e.g. 123
  - hexadecimal: e.g. 0x3F
  - other bases in the format n\_xxx where
    - n is the base
    - xxx is the number in that base

# Constant allocation in code memory

```
{label} DCxx expr{,expr}...
```

- The available directives are:
  - DCB: define constant byte
  - DCW: define constant half-word
  - **DCWU**: define constant half-word unaligned
  - DCD: define constant word
  - **DCDU**: define constant word unaligned
- expr is:
  - a numeric expression in the proper range
  - a string (with DCB only)

## **DCB**

myData DCB 65, 0x73, 8\_163 DCB "embly"

| Address    | Value | Octal                              | Hex | ASCII |
|------------|-------|------------------------------------|-----|-------|
| 0x00000D2  | 65    | 101                                | 41  | Α     |
| 0x00000D3  | 115   | 163                                | 73  | S     |
| 0x00000D4  | 115   | 163                                | 73  | S     |
| 0x00000D5  | 101   | 145                                | 65  | е     |
| 0x00000D6  | 109   | 155                                | 6D  | m     |
| 0x00000D7  | 98    | 142                                | 62  | b     |
| 0x000000D8 | 108   | 154                                | 6C  | I     |
| 0x00000D9  | 121   | 171 Architectures - Politechico di | 79  | У     |

Computer Architectures - Politecnico di Torino

## **DCW**

myData DCB 65, 0x73, 8 163 DCW 0x626D, 0x796C

| Address    | Value | Octal                              | Hex       | ASCII |
|------------|-------|------------------------------------|-----------|-------|
| 0x00000D2  | 65    | 101                                | 41        | Α     |
| 0x00000D3  | 115   | 163                                | 73        | S     |
| 0x00000D4  | 115   | 163                                | 73        | S     |
| 0x00000D5  | 0     | 0                                  | 0         | NUL   |
| 0x00000D6  | 109   | 155                                | 6D        | m     |
| 0x00000D7  | 98    | 142                                | 62        | b     |
| 0x000000D8 | 108   | 154                                | 6C        | I     |
| 0x00000D9  | 121   | 171 Architectures - Politecnico di | <b>79</b> | У     |

Computer Architectures - Politechico di Torino

## **DCWU**

myData DCB 65, 0x73, 8\_163 DCWU 0x626D, 0x796C

| Address    | Value | Octal | Hex | ASCII |
|------------|-------|-------|-----|-------|
| 0x00000D2  | 65    | 101   | 41  | А     |
| 0x00000D3  | 115   | 163   | 73  | S     |
| 0x00000D4  | 115   | 163   | 73  | S     |
| 0x00000D5  | 109   | 155   | 6D  | m     |
| 0x00000D6  | 98    | 142   | 62  | b     |
| 0x00000D7  | 108   | 154   | 6C  | I     |
| 0x000000D8 | 121   | 171   | 79  | У     |

#### DCD

myData DCB 65, 0x73, 8\_163 DCD 0x796C626D

| Address   | Value | Octal | Hex | ASCII |
|-----------|-------|-------|-----|-------|
| 0x00000D2 | 65    | 101   | 41  | А     |
| 0x00000D3 | 115   | 163   | 73  | S     |
| 0x00000D4 | 115   | 163   | 73  | S     |
| 0x00000D5 | 0     | 0     | 0   | NUL   |
| 0x00000D6 | 0     | 0     | 0   | NUL   |
| 0x00000D7 | 0     | 0     | 0   | NUL   |
| 0x00000D8 | 109   | 155   | 6D  | m     |
| 0x00000D9 | 98    | 142   | 62  | b     |
| 0x00000DA | 108   | 154   | 6C  | I     |
| 0x00000DB | 121   | 171   | 79  | У     |

Computer Architectures - Politecnico di Torino

## **DCDU**

myData DCB 65, 0x73, 8\_163 DCDU 0x796C626D

| Address   | Value | Octal | Hex | ASCII |
|-----------|-------|-------|-----|-------|
| 0x00000D2 | 65    | 101   | 41  | А     |
| 0x00000D3 | 115   | 163   | 73  | S     |
| 0x00000D4 | 115   | 163   | 73  | S     |
| 0x00000D5 | 109   | 155   | 6D  | m     |
| 0x00000D6 | 98    | 142   | 62  | b     |
| 0x00000D7 | 108   | 154   | 6C  | I     |
| 0x00000D8 | 121   | 171   | 79  | У     |

# Align

• The ALIGN directive aligns the current location to a specified boundary by padding with zeros:

• The current location is aligned to the next address of the form

- If expr is not specified, ALIGN sets the current location to the next word boundary.
- Example: The ADR Thumb pseudo-instruction can only load addresses that are word aligned, but a label within Thumb code might not be word aligned. Use ALIGN 4 to ensure four-byte alignment of an address within Thumb code.

# Align expr

myData DCB 65

ALIGN 2

DCB 115

| Address   | Value | Octal | Hex | ASCII |
|-----------|-------|-------|-----|-------|
| 0x00000D4 | 65    | 101   | 41  | А     |
| 0x00000D5 | 0     | 0     | 0   | NUL   |
| 0x00000D6 | 115   | 163   | 73  | S     |

# Align expr

myData DCB 65

ALIGN 4

DCB 115

| Address    | Value | Octal | Hex | ASCII |
|------------|-------|-------|-----|-------|
| 0x00000D4  | 65    | 101   | 41  | А     |
| 0x00000D5  | 0     | 0     | 0   | NUL   |
| 0x00000D6  | 0     | 0     | 0   | NUL   |
| 0x00000D7  | 0     | 0     | 0   | NUL   |
| 0x000000D8 | 115   | 163   | 73  | S     |

# Reserving a block of memory

• The SPACE directive reserves a zeroed block of memory:

```
{label} SPACE expr
```

- expr is the number of bytes to reserve
- Example:

```
long_var SPACE 8
```

# Ending the source file

• The END directive tells the assembler that the current location is the end of the source file:

END